<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>User-Defined-Alert</title>
  <style>
    .userDefinedAlert{
      position: fixed;
      top: 300px;
      left: 50%;
      transform: translateX(-50%);
      width: 300px;
      height: 100px;
      box-shadow: gray 3px 3px 10px;
    }
    .alertBtnClose{
      display: block;
      margin: 70px auto;
    }
  </style>
</head>
<body>
  <div class="content">
  </div>
</body>
<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
<script>
$(function(){
  // 初始
  for(let i = 0;i<100; i++){
    $(".content").append(
      `<div>---
      </br>
      ${'---'+i}
      </br>
      </div>`
    )
    if(i == 20){
      $(".content").append(
        `<button class="alert-btn">Alert</button>`
      )
    }
  }
  // 创建弹窗
  $(".alert-btn").click(function(){
    $("body").append(
      `<div class="userDefinedAlert">
        <button class="alertBtnClose">Close</buttom>
      </div>`
    )
    // 此时弹窗不会阻止窗口，只需定义body的overflow属性值为隐藏即可
    $("body").css("overflow","hidden");
    // 此时页面已滚动效果已被冻结，关闭弹窗需要重新开启滚动效果
    $(".alertBtnClose").click(function(){
      // 关闭弹窗
      $(".userDefinedAlert").remove();
      // 开启滚动
      $("body").css("overflow","auto");
    })

  })
})
</script>
</html>